# **Verilog CheatSheet**

# Oficina Introdução ao Verilog Comportamental XXXI SIECOMP

#### **OPERADORES**

| +  | a = b + c | Soma binária                        | =                   | a = b   | a recebe o valor de b                                             |
|----|-----------|-------------------------------------|---------------------|---------|-------------------------------------------------------------------|
| -  | a = b - c | Subtração binária                   | ==                  | a == b  | a é igual a b?                                                    |
| I  | a =  b    | OR para todos os bits de b          | ===                 | a === b | a é igual a b? (inclui X e Z)                                     |
| &  | a = &b    | AND para todos o bits de b          | !=                  | a != b  | a é diferente de b?                                               |
| ^  | a = ^b    | XOR para todos o bits de b          | !==                 | a !== b | a é diferente de b? (inclui X e Z)                                |
| ~  | a = ~ b   | NOR para todos o bits de b          | <b>&lt;&lt;</b>     | a << n  | desloca a à esquerda n vezes e<br>completa com 0                  |
| ~& | a = ~&b   | NAND para todos o bits de b         | >>                  | a >> n  | desloca a à direita n vezes e<br>completa com 0                   |
| ~^ | a = ~^    | XNOR para todos o bits de b         | <b>&lt;&lt;&lt;</b> | a <<< n | desloca a à esquerda n vezes e<br>completa com 0 (mantém o sinal) |
| {} | a = {b,c} | concatena 'b' e 'c' e atribui a 'a' | >>>                 | a >>> n | desloca a à direita n vezes e<br>completa com 0 (mantém o sinal)  |

## **DEFINIÇÃO DE MÓDULOS**

#### endmodule

# INSTANCIAÇÃO DE MÓDULO



#### **ASSIGN**

assign <variável> = <expressão>;

## **ATRIBUIÇÕES**

• Bloqueante: usada em circuitos combinacionais

a = <expressão>

Não bloqueante: usada em circuitos sequenciais

```
a <= <expressão>
```

#### **BLOCOS**

Always

```
always @ (<lista_de_triggers>) begin
```

#### end

Exemplos de triggers: \*, posedge <sinal>, negedge <sinal>, sinal1 <operador> sinal2 <operador> sinal3 ...

initial

- begin ... end: agrupa múltiplas declarações para serem executadas sequencialmente
- fork ... join: agrupa múltiplas declarações para serem executadas paralelamente

#### **ESTRUTURAS DE DECISÃO**

```
CASE
case (<expressao>)
case_item1:
    <declaracao_unica>
case_item2:
    <br/>begin
    <declaracoes_multiplas>
    end
    default:
    <declaracao_unica>
endcase
```